[INFO] cloning repository https://github.com/iolsen/sfb
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/iolsen/sfb" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fiolsen%2Fsfb", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fiolsen%2Fsfb'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] e1b3df9ee9907fd819df9f8400113fc25b475a5c
[INFO] checking iolsen/sfb against master#029c9e18dd1f4668e1d42bb187c1c263dfe20093 for pr-157562
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fiolsen%2Fsfb" "/workspace/builds/worker-0-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/iolsen/sfb
[INFO] finished tweaking git repo https://github.com/iolsen/sfb
[INFO] tweaked toml for git repo https://github.com/iolsen/sfb written to /workspace/builds/worker-0-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/iolsen/sfb on toolchain 029c9e18dd1f4668e1d42bb187c1c263dfe20093
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+029c9e18dd1f4668e1d42bb187c1c263dfe20093" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/iolsen/sfb already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+029c9e18dd1f4668e1d42bb187c1c263dfe20093" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded proc-macro2 v1.0.13
[INFO] [stderr]   Downloaded imgui-gfx-renderer v0.3.0
[INFO] [stderr]   Downloaded syn v1.0.22
[INFO] [stderr]   Downloaded imgui v0.3.0
[INFO] [stderr]   Downloaded imgui-sys v0.3.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-m" "1610612736" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:3e793bdf10248eb2ddbd6b0faebed8155c11b4589982e2893733958d93e8d540" "sleep" "infinity", kill_on_drop: false }`
[INFO] [stdout] 9d7da08dd72550a786f018233bae30f3971dac18a24fa76952db07728ba98e06
[INFO] running `Command { std: "docker" "start" "9d7da08dd72550a786f018233bae30f3971dac18a24fa76952db07728ba98e06", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "exec" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-w" "/opt/rustwide/workdir" "--user" "0:0" "9d7da08dd72550a786f018233bae30f3971dac18a24fa76952db07728ba98e06" "/opt/rustwide/cargo-home/bin/cargo" "+029c9e18dd1f4668e1d42bb187c1c263dfe20093" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "9d7da08dd72550a786f018233bae30f3971dac18a24fa76952db07728ba98e06", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "exec" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-w" "/opt/rustwide/workdir" "--user" "0:0" "9d7da08dd72550a786f018233bae30f3971dac18a24fa76952db07728ba98e06" "/opt/rustwide/cargo-home/bin/cargo" "+029c9e18dd1f4668e1d42bb187c1c263dfe20093" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.70
[INFO] [stderr]    Compiling autocfg v1.0.0
[INFO] [stderr]    Compiling cc v1.0.53
[INFO] [stderr]    Compiling log v0.4.8
[INFO] [stderr]    Compiling proc-macro2 v1.0.13
[INFO] [stderr]    Compiling unicode-xid v0.2.0
[INFO] [stderr]    Compiling syn v1.0.22
[INFO] [stderr]    Compiling serde v1.0.110
[INFO] [stderr]    Compiling pkg-config v0.3.17
[INFO] [stderr]    Compiling getrandom v0.1.14
[INFO] [stderr]    Compiling gimli v0.21.0
[INFO] [stderr]    Compiling ryu v1.0.4
[INFO] [stderr]    Compiling version_check v0.9.1
[INFO] [stderr]    Compiling rustc-demangle v0.1.16
[INFO] [stderr]     Checking downcast-rs v1.1.1
[INFO] [stderr]    Compiling object v0.19.0
[INFO] [stderr]    Compiling itoa v0.4.5
[INFO] [stderr]     Checking ppv-lite86 v0.2.8
[INFO] [stderr]    Compiling remove_dir_all v0.5.2
[INFO] [stderr]    Compiling gl_generator v0.13.1
[INFO] [stderr]    Compiling error-chain v0.12.2
[INFO] [stderr]    Compiling gl_generator v0.14.0
[INFO] [stderr]     Checking gfx_core v0.9.2
[INFO] [stderr]     Checking xi-unicode v0.2.0
[INFO] [stderr]    Compiling num-traits v0.2.11
[INFO] [stderr]    Compiling memoffset v0.5.4
[INFO] [stderr]    Compiling crossbeam-utils v0.7.2
[INFO] [stderr]    Compiling crossbeam-epoch v0.8.2
[INFO] [stderr]    Compiling num-integer v0.1.42
[INFO] [stderr]    Compiling num-rational v0.2.4
[INFO] [stderr]    Compiling num-complex v0.2.4
[INFO] [stderr]    Compiling x11-dl v2.18.5
[INFO] [stderr]    Compiling alsa-sys v0.1.2
[INFO] [stderr]    Compiling libudev-sys v0.1.4
[INFO] [stderr]    Compiling num-iter v0.1.40
[INFO] [stderr]    Compiling bytecount v0.4.0
[INFO] [stderr]     Checking smallvec v1.4.0
[INFO] [stderr]     Checking deflate v0.7.20
[INFO] [stderr]     Checking jpeg-decoder v0.1.19
[INFO] [stderr]    Compiling imgui-gfx-renderer v0.3.0
[INFO] [stderr]    Compiling quote v1.0.5
[INFO] [stderr]    Compiling gfx_gl v0.6.1
[INFO] [stderr]     Checking gfx v0.18.2
[INFO] [stderr]    Compiling glutin_glx_sys v0.1.6
[INFO] [stderr]    Compiling glutin_egl_sys v0.1.4
[INFO] [stderr]     Checking podio v0.1.6
[INFO] [stderr]     Checking claxon v0.4.2
[INFO] [stderr]     Checking crossbeam-deque v0.7.3
[INFO] [stderr]     Checking png v0.15.3
[INFO] [stderr]    Compiling libloading v0.5.2
[INFO] [stderr]    Compiling bzip2-sys v0.1.8+1.0.8
[INFO] [stderr]    Compiling minimp3-sys v0.3.2
[INFO] [stderr]     Checking num_cpus v1.13.0
[INFO] [stderr]     Checking nix v0.14.1
[INFO] [stderr]    Compiling rand v0.4.6
[INFO] [stderr]     Checking approx v0.3.2
[INFO] [stderr]     Checking ordered-float v1.0.2
[INFO] [stderr]     Checking euclid v0.19.9
[INFO] [stderr]     Checking line_drawing v0.7.0
[INFO] [stderr]     Checking rand_core v0.5.1
[INFO] [stderr]     Checking rusttype v0.8.3
[INFO] [stderr]     Checking num-traits v0.1.43
[INFO] [stderr]     Checking dlib v0.4.1
[INFO] [stderr]     Checking memmap v0.7.0
[INFO] [stderr]     Checking rand_chacha v0.2.2
[INFO] [stderr]     Checking sid v0.5.2
[INFO] [stderr]     Checking wayland-sys v0.21.13
[INFO] [stderr]     Checking rusttype v0.7.9
[INFO] [stderr]     Checking andrew v0.2.1
[INFO] [stderr]     Checking rand v0.7.3
[INFO] [stderr]     Checking raw-window-handle v0.3.3
[INFO] [stderr]     Checking shared_library v0.1.9
[INFO] [stderr]     Checking rand_os v0.1.3
[INFO] [stderr]    Compiling imgui-sys v0.3.0
[INFO] [stderr]     Checking rand v0.6.5
[INFO] [stderr]     Checking osmesa-sys v0.1.2
[INFO] [stderr]    Compiling addr2line v0.12.0
[INFO] [stderr]     Checking lyon_geom v0.12.7
[INFO] [stderr]    Compiling backtrace v0.3.48
[INFO] [stderr]     Checking glyph_brush_layout v0.1.9
[INFO] [stderr]     Checking alga v0.9.3
[INFO] [stderr]    Compiling tempdir v0.3.7
[INFO] [stderr]     Checking parking_lot_core v0.7.2
[INFO] [stderr]     Checking slice-deque v0.3.0
[INFO] [stderr]     Checking nix v0.15.0
[INFO] [stderr]     Checking bzip2 v0.3.3
[INFO] [stderr]     Checking parking_lot v0.10.2
[INFO] [stderr]     Checking tiff v0.3.1
[INFO] [stderr]     Checking cpal v0.8.2
[INFO] [stderr]     Checking dirs-sys v0.3.4
[INFO] [stderr]     Checking lyon_path v0.13.2
[INFO] [stderr]     Checking zip v0.5.5
[INFO] [stderr]     Checking directories v2.0.2
[INFO] [stderr]     Checking minimp3 v0.3.5
[INFO] [stderr]     Checking nalgebra v0.18.1
[INFO] [stderr]     Checking twox-hash v1.5.0
[INFO] [stderr]     Checking glyph_brush v0.6.3
[INFO] [stderr]     Checking lyon_tessellation v0.13.5
[INFO] [stderr]     Checking lyon_algorithms v0.13.4
[INFO] [stderr]     Checking image v0.22.5
[INFO] [stderr]     Checking glyph_brush v0.5.4
[INFO] [stderr]     Checking lyon v0.13.5
[INFO] [stderr]     Checking wayland-commons v0.21.13
[INFO] [stderr]     Checking wayland-client v0.21.13
[INFO] [stderr]     Checking gfx_device_gl v0.16.2
[INFO] [stderr]     Checking wayland-protocols v0.21.13
[INFO] [stderr]    Compiling serde_derive v1.0.110
[INFO] [stderr]     Checking gilrs-core v0.2.6
[INFO] [stderr]     Checking gilrs v0.7.4
[INFO] [stderr]     Checking smithay-client-toolkit v0.4.6
[INFO] [stderr]     Checking imgui v0.3.0
[INFO] [stderr]     Checking rodio v0.9.0
[INFO] [stderr]     Checking toml v0.5.6
[INFO] [stderr]    Compiling semver v0.9.0
[INFO] [stderr]    Compiling serde_json v1.0.53
[INFO] [stderr]    Compiling rustc_version v0.2.3
[INFO] [stderr]    Compiling parking_lot_core v0.6.2
[INFO] [stderr]    Compiling parking_lot v0.9.0
[INFO] [stderr]     Checking winit v0.19.5
[INFO] [stderr]    Compiling cargo_metadata v0.6.4
[INFO] [stderr]    Compiling skeptic v0.13.4
[INFO] [stderr]     Checking glutin v0.20.1
[INFO] [stderr]    Compiling ggez v0.5.1
[INFO] [stderr]     Checking gfx_window_glutin v0.30.0
[INFO] [stderr]     Checking sfb v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: enum `BearingTo` is never used
[INFO] [stdout]   --> src/hex.rs:68:10
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub enum BearingTo {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Cube` is never constructed
[INFO] [stdout]    --> src/hex.rs:108:8
[INFO] [stdout]     |
[INFO] [stdout] 108 | struct Cube {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/hex.rs:132:12
[INFO] [stdout]     |
[INFO] [stdout] 120 | impl Hex {
[INFO] [stdout]     | -------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 132 |     pub fn from_label(label: &str) -> Option<Hex> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 155 |     pub fn distance_to(&self, other: &Hex) -> i8 {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 159 |     pub fn bearing_to(&self, other: &Hex) -> BearingTo {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 186 |     fn angle_to(&self, other: &Hex) -> i16 {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 215 |     fn center_coords(&self) -> Point2<f32> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 247 |     fn to_cube(&self) -> Cube {
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 254 |     fn cubic_distance(a: Cube, b: Cube) -> i8 {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `height` is never read
[INFO] [stdout]  --> src/screen/map.rs:8:9
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct MapState {
[INFO] [stdout]   |            -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 8 |     pub height: f32,
[INFO] [stdout]   |         ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `speed` and `spec` are never read
[INFO] [stdout]   --> src/ship.rs:29:9
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct Ship {
[INFO] [stdout]    |            ---- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 29 |     pub speed: u8,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 30 |
[INFO] [stdout] 31 |     spec: ShipSpec,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_energy_allocation` and `rotate_to` are never used
[INFO] [stdout]    --> src/ship.rs:97:12
[INFO] [stdout]     |
[INFO] [stdout]  39 | impl Ship {
[INFO] [stdout]     | --------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  97 |     pub fn set_energy_allocation(&mut self, e: EnergyAllocation) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 102 |     pub fn rotate_to(&mut self, new_facing: Facing) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `defenses`, `power`, and `ship` are never read
[INFO] [stdout]   --> src/ship_spec.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub struct ShipSpec {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 10 |     pub fx: Fx,
[INFO] [stdout] 11 |     pub defenses: Defenses,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 12 |     pub power: Power,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 13 |     pub ship: Ship,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/ship_spec.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct Defenses {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 23 |     pub shield1: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 24 |     pub shield2: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 25 |     pub shield3: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 26 |     pub shield4: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 27 |     pub shield5: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 28 |     pub shield6: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 29 |     pub armor: u8,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `left_warp`, `center_warp`, `right_warp`, `impulse`, and `battery` are never read
[INFO] [stdout]   --> src/ship_spec.rs:34:9
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub struct Power {
[INFO] [stdout]    |            ----- fields in this struct
[INFO] [stdout] 34 |     pub left_warp: u8,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 35 |     pub center_warp: u8,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 36 |     pub right_warp: u8,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 37 |     pub impulse: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 38 |     pub battery: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `forward_hull` and `aft_hull` are never read
[INFO] [stdout]   --> src/ship_spec.rs:43:9
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub struct Ship {
[INFO] [stdout]    |            ---- fields in this struct
[INFO] [stdout] 43 |     pub forward_hull: u8,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 44 |     pub aft_hull: u8,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]  --> src/screen/energy_allocation_window.rs:9:19
[INFO] [stdout]   |
[INFO] [stdout] 9 |     pub fn new(e: &EnergyAllocation) -> EnergyAllocationWindow {
[INFO] [stdout]   |                   ^^^^^^^^^^^^^^^^^     ^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]   |                   |
[INFO] [stdout]   |                   the lifetime is elided here
[INFO] [stdout]   |
[INFO] [stdout]   = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]   = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]   |
[INFO] [stdout] 9 |     pub fn new(e: &EnergyAllocation) -> EnergyAllocationWindow<'_> {
[INFO] [stdout]   |                                                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]  --> src/ship_spec.rs:8:10
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Deserialize)]
[INFO] [stdout]   |          ^----------
[INFO] [stdout]   |          |
[INFO] [stdout]   |          `Deserialize` is not local
[INFO] [stdout]   |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_ShipSpec`
[INFO] [stdout] 9 | pub struct ShipSpec {
[INFO] [stdout]   |            -------- `ShipSpec` is not local
[INFO] [stdout]   |
[INFO] [stdout]   = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]   = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]   = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]   = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]   = note: `#[warn(non_local_definitions)]` on by default
[INFO] [stdout]   = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]   --> src/ship_spec.rs:16:10
[INFO] [stdout]    |
[INFO] [stdout] 16 | #[derive(Deserialize)]
[INFO] [stdout]    |          ^----------
[INFO] [stdout]    |          |
[INFO] [stdout]    |          `Deserialize` is not local
[INFO] [stdout]    |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_Fx`
[INFO] [stdout] 17 | pub struct Fx {
[INFO] [stdout]    |            -- `Fx` is not local
[INFO] [stdout]    |
[INFO] [stdout]    = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]    = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]    = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]    = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]    = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]   --> src/ship_spec.rs:21:10
[INFO] [stdout]    |
[INFO] [stdout] 21 | #[derive(Deserialize)]
[INFO] [stdout]    |          ^----------
[INFO] [stdout]    |          |
[INFO] [stdout]    |          `Deserialize` is not local
[INFO] [stdout]    |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_Defenses`
[INFO] [stdout] 22 | pub struct Defenses {
[INFO] [stdout]    |            -------- `Defenses` is not local
[INFO] [stdout]    |
[INFO] [stdout]    = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]    = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]    = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]    = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]    = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]   --> src/ship_spec.rs:32:10
[INFO] [stdout]    |
[INFO] [stdout] 32 | #[derive(Deserialize)]
[INFO] [stdout]    |          ^----------
[INFO] [stdout]    |          |
[INFO] [stdout]    |          `Deserialize` is not local
[INFO] [stdout]    |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_Power`
[INFO] [stdout] 33 | pub struct Power {
[INFO] [stdout]    |            ----- `Power` is not local
[INFO] [stdout]    |
[INFO] [stdout]    = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]    = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]    = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]    = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]    = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]   --> src/ship_spec.rs:41:10
[INFO] [stdout]    |
[INFO] [stdout] 41 | #[derive(Deserialize)]
[INFO] [stdout]    |          ^----------
[INFO] [stdout]    |          |
[INFO] [stdout]    |          `Deserialize` is not local
[INFO] [stdout]    |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_Ship`
[INFO] [stdout] 42 | pub struct Ship {
[INFO] [stdout]    |            ---- `Ship` is not local
[INFO] [stdout]    |
[INFO] [stdout]    = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]    = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]    = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]    = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]    = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `height` is never read
[INFO] [stdout]  --> src/screen/map.rs:8:9
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct MapState {
[INFO] [stdout]   |            -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 8 |     pub height: f32,
[INFO] [stdout]   |         ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `speed` and `spec` are never read
[INFO] [stdout]   --> src/ship.rs:29:9
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct Ship {
[INFO] [stdout]    |            ---- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 29 |     pub speed: u8,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 30 |
[INFO] [stdout] 31 |     spec: ShipSpec,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_energy_allocation` and `rotate_to` are never used
[INFO] [stdout]    --> src/ship.rs:97:12
[INFO] [stdout]     |
[INFO] [stdout]  39 | impl Ship {
[INFO] [stdout]     | --------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  97 |     pub fn set_energy_allocation(&mut self, e: EnergyAllocation) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 102 |     pub fn rotate_to(&mut self, new_facing: Facing) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `defenses`, `power`, and `ship` are never read
[INFO] [stdout]   --> src/ship_spec.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub struct ShipSpec {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 10 |     pub fx: Fx,
[INFO] [stdout] 11 |     pub defenses: Defenses,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 12 |     pub power: Power,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 13 |     pub ship: Ship,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/ship_spec.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct Defenses {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 23 |     pub shield1: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 24 |     pub shield2: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 25 |     pub shield3: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 26 |     pub shield4: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 27 |     pub shield5: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 28 |     pub shield6: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 29 |     pub armor: u8,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `left_warp`, `center_warp`, `right_warp`, `impulse`, and `battery` are never read
[INFO] [stdout]   --> src/ship_spec.rs:34:9
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub struct Power {
[INFO] [stdout]    |            ----- fields in this struct
[INFO] [stdout] 34 |     pub left_warp: u8,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 35 |     pub center_warp: u8,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 36 |     pub right_warp: u8,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 37 |     pub impulse: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 38 |     pub battery: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `forward_hull` and `aft_hull` are never read
[INFO] [stdout]   --> src/ship_spec.rs:43:9
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub struct Ship {
[INFO] [stdout]    |            ---- fields in this struct
[INFO] [stdout] 43 |     pub forward_hull: u8,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 44 |     pub aft_hull: u8,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]  --> src/screen/energy_allocation_window.rs:9:19
[INFO] [stdout]   |
[INFO] [stdout] 9 |     pub fn new(e: &EnergyAllocation) -> EnergyAllocationWindow {
[INFO] [stdout]   |                   ^^^^^^^^^^^^^^^^^     ^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]   |                   |
[INFO] [stdout]   |                   the lifetime is elided here
[INFO] [stdout]   |
[INFO] [stdout]   = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]   = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]   |
[INFO] [stdout] 9 |     pub fn new(e: &EnergyAllocation) -> EnergyAllocationWindow<'_> {
[INFO] [stdout]   |                                                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]  --> src/ship_spec.rs:8:10
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Deserialize)]
[INFO] [stdout]   |          ^----------
[INFO] [stdout]   |          |
[INFO] [stdout]   |          `Deserialize` is not local
[INFO] [stdout]   |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_ShipSpec`
[INFO] [stdout] 9 | pub struct ShipSpec {
[INFO] [stdout]   |            -------- `ShipSpec` is not local
[INFO] [stdout]   |
[INFO] [stdout]   = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]   = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]   = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]   = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]   = note: `#[warn(non_local_definitions)]` on by default
[INFO] [stdout]   = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]   --> src/ship_spec.rs:16:10
[INFO] [stdout]    |
[INFO] [stdout] 16 | #[derive(Deserialize)]
[INFO] [stdout]    |          ^----------
[INFO] [stdout]    |          |
[INFO] [stdout]    |          `Deserialize` is not local
[INFO] [stdout]    |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_Fx`
[INFO] [stdout] 17 | pub struct Fx {
[INFO] [stdout]    |            -- `Fx` is not local
[INFO] [stdout]    |
[INFO] [stdout]    = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]    = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]    = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]    = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]    = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]   --> src/ship_spec.rs:21:10
[INFO] [stdout]    |
[INFO] [stdout] 21 | #[derive(Deserialize)]
[INFO] [stdout]    |          ^----------
[INFO] [stdout]    |          |
[INFO] [stdout]    |          `Deserialize` is not local
[INFO] [stdout]    |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_Defenses`
[INFO] [stdout] 22 | pub struct Defenses {
[INFO] [stdout]    |            -------- `Defenses` is not local
[INFO] [stdout]    |
[INFO] [stdout]    = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]    = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]    = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]    = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]    = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]   --> src/ship_spec.rs:32:10
[INFO] [stdout]    |
[INFO] [stdout] 32 | #[derive(Deserialize)]
[INFO] [stdout]    |          ^----------
[INFO] [stdout]    |          |
[INFO] [stdout]    |          `Deserialize` is not local
[INFO] [stdout]    |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_Power`
[INFO] [stdout] 33 | pub struct Power {
[INFO] [stdout]    |            ----- `Power` is not local
[INFO] [stdout]    |
[INFO] [stdout]    = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]    = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]    = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]    = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]    = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]   --> src/ship_spec.rs:41:10
[INFO] [stdout]    |
[INFO] [stdout] 41 | #[derive(Deserialize)]
[INFO] [stdout]    |          ^----------
[INFO] [stdout]    |          |
[INFO] [stdout]    |          `Deserialize` is not local
[INFO] [stdout]    |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_Ship`
[INFO] [stdout] 42 | pub struct Ship {
[INFO] [stdout]    |            ---- `Ship` is not local
[INFO] [stdout]    |
[INFO] [stdout]    = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]    = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]    = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]    = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]    = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 51.45s
[INFO] running `Command { std: "docker" "inspect" "9d7da08dd72550a786f018233bae30f3971dac18a24fa76952db07728ba98e06", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9d7da08dd72550a786f018233bae30f3971dac18a24fa76952db07728ba98e06", kill_on_drop: false }`
[INFO] [stdout] 9d7da08dd72550a786f018233bae30f3971dac18a24fa76952db07728ba98e06
